# RISC V



|             |   | 31    | 30 | 29   | 28     | 27     | 26   | 25      | 24         | 23 | 22         | 21      | 20   | 19 | 18 | 17   | 16      | 15    | 14  | 13      | 12 | 11   | 10  | 9       | 8         | 7     | 6   | 5 | 4 | 3      | 3 2    |               | 1 (   | 0        |    |
|-------------|---|-------|----|------|--------|--------|------|---------|------------|----|------------|---------|------|----|----|------|---------|-------|-----|---------|----|------|-----|---------|-----------|-------|-----|---|---|--------|--------|---------------|-------|----------|----|
| Load        | I |       |    |      |        |        | imm[ | 11:0]   |            |    |            |         |      |    |    | rs1  |         |       | f   | unct3   |    |      |     | rd      |           |       |     |   |   | ор     |        |               |       |          | 12 |
| Chaus       | S |       |    | :    | [11    | 1      |      |         |            |    | <b>#60</b> |         |      |    |    | ua 1 |         |       |     | . m a+0 |    |      |     | [ A · C | 17        |       |     |   |   |        |        |               |       | 1        | 10 |
| Store       | 3 |       |    | 1111 | ım[11: | .၁]    |      |         |            |    | rs2        |         |      |    |    | rs1  |         |       | - 1 | unct3   |    |      | III | nm[4:0  | <u>']</u> |       |     |   |   | op     | _      |               |       | <u></u>  | 12 |
| Data        | R |       |    | f    | unct7  | 7      |      |         |            |    | rs2        |         |      |    |    | rs1  |         |       | f   | unct3   |    |      |     | rd      |           |       |     |   |   | ор     |        |               |       |          |    |
| Load imm    | U |       |    |      |        |        |      |         |            | i  | imm[3      | 1.101   |      |    |    |      |         |       |     |         |    |      |     | rd      |           |       |     |   |   | on     |        |               |       |          | 20 |
| Load IIIIII | U |       |    |      |        |        |      |         |            |    | ıııııı     | 01.12]  |      |    |    |      |         |       |     |         |    |      |     | Tu      |           |       |     |   |   | op     |        |               |       |          | 20 |
| Branch      | В | i[12] |    |      | imm[   | [10:5] |      |         |            |    | rs2        |         |      |    |    | rs1  |         |       | f   | unct3   |    |      | imm | [4:1]   |           | i[11] |     |   |   | ор     |        |               |       |          | 12 |
| Jump        | J | i[20] |    |      |        |        | imm[ | 10:1]   |            |    |            | i       | [11] |    |    |      | imm[1   | 9:12] |     |         |    |      |     | rd      |           |       |     |   |   | ор     |        |               |       |          | 20 |
|             |   |       |    |      |        |        |      |         |            |    |            |         |      |    |    |      |         |       |     |         |    |      |     |         |           |       |     |   |   |        |        |               |       |          |    |
|             |   |       |    |      |        |        |      |         |            |    |            |         |      |    |    |      |         |       |     |         |    |      |     |         |           |       |     |   |   |        |        |               |       |          |    |
|             |   | 31    | 30 | 29   | 28     | 27     | 26   | 25      | 24         | 23 | 22         | 21      | 20   | 19 | 18 | 17   | 16      | 15    | 14  | 13      | 12 | 11   | 10  | 9       | 8         | 7     | 6   | 5 | 4 | 3      | 3 2    | :             | 1 (   | 0        |    |
| Load        | ı |       |    |      |        |        |      |         |            |    | ir         | ıst[31] |      |    |    |      |         |       |     |         |    |      |     |         | inst[3    | 0:251 |     |   |   | inst[' | 24:21] |               | i[20] |          |    |
| 2544        |   |       |    |      |        |        |      |         |            |    |            | .0.[01] |      |    |    |      |         |       |     |         | ĺ  |      |     |         | moteo     | 0.201 |     |   |   | moq.   |        |               | ·[LU] | •        |    |
| Store       | S |       | ·  |      |        |        |      |         |            |    | ir         | ıst[31] |      |    |    |      |         |       |     |         |    |      |     |         | inst[3    | 0:25] |     |   |   | inst   | [11:8] |               | i[7]  | <u> </u> |    |
| Load imm    | U | i[31] |    |      |        |        | ing  | st[30:2 | <b>Ω</b> 1 |    |            |         |      |    |    |      | inst[19 | 9-121 |     |         |    |      |     |         |           |       | 0   |   |   |        |        |               |       | 1        |    |
| Load IIIIII | U | ı[ər] | I  |      |        |        | 1118 | ι[30.Z  | oj –       | ĺ  |            |         |      |    |    | ĺ    | шэцт    | 9.12j |     |         |    |      |     |         |           |       | - 0 |   |   |        |        | $\overline{}$ |       |          |    |
| Branch      | В |       |    |      |        |        |      |         |            |    | inst[      | 31]     |      |    |    |      |         |       |     |         | į  | [7]  |     |         | inst[3    | 0:25] |     |   |   | inst   | [11:8] |               | (     | 3        |    |
|             |   |       |    |      |        |        |      |         |            |    |            |         |      |    |    |      |         |       |     |         |    |      |     |         |           |       |     |   |   |        |        |               |       |          |    |
| Jump        | J |       |    |      |        |        | inst | [31]    |            |    |            |         |      |    |    | i    | imm[1   | 9:12] |     |         | i  | [20] |     |         | inst[3    | 0:25] |     |   |   | inst[  | 24:21] |               | (     | )        |    |

| 31 30 25 24       | 21 20    | 19  | 15 14 12 | 2 11 8 7           | 6 0    |          |
|-------------------|----------|-----|----------|--------------------|--------|----------|
| funct7            | rs2      | rs1 | funct3   | rd                 | opcode | R-type   |
| ·                 |          | •   | •        |                    |        | •        |
| imm[11:0]         |          | rs1 | funct3   | rd                 | opcode | l-type   |
|                   |          |     | -        | -                  |        | •        |
| imm[11:5]         | rs2      | rs1 | funct3   | imm[4:0]           | opcode | S-type   |
| •                 |          |     | -        |                    |        | •        |
| imm[12] imm[10:5] | rs2      | rs1 | funct3   | imm[4:1]   imm[11] | opcode | B-type   |
|                   |          |     | -        | -                  |        | •        |
| im                | m[31:12] |     |          | rd                 | opcode | U-type   |
|                   |          |     |          | -                  |        | •        |
| imm[20] imm[10:1] | imm[11]  | imm | [19:12]  | rd                 | opcode | ] J-type |

| 31       | 30           | 20 19       | 12 | 11       | 10        | 5        | 4 1         | 0        |             |
|----------|--------------|-------------|----|----------|-----------|----------|-------------|----------|-------------|
|          | <u> —</u> in | st[31] —    |    |          | inst[30:2 | 25]      | inst[24:21] | inst[20] | I-immediate |
|          |              |             |    |          |           |          |             |          |             |
|          | <u> —</u> in | st[31] —    |    |          | inst[30:2 | 25]      | inst[11:8]  | inst[7]  | S-immediate |
|          |              |             |    |          |           |          |             |          |             |
|          | — inst[31    | ] —         |    | inst[7]  | inst[30:2 | 25]      | inst[11:8]  | 0        | B-immediate |
|          |              |             |    |          |           |          |             |          |             |
| inst[31] | inst[30:20]  | inst[19:12] |    |          | _         | <u> </u> | ) —         |          | U-immediate |
|          |              |             |    |          |           |          |             |          |             |
|          | inst[31] —   | inst[19:12] |    | inst[20] | inst[30:2 | 25]      | inst[24:21] | 0        | J-immediate |

#### RISC-V RV32IM ISA Reference Sheet v1.4

| 31       | 25    | 24    | 20     | 19      | 15  | 14  | 12  | 11  | 7        | 6   | 0   |        |
|----------|-------|-------|--------|---------|-----|-----|-----|-----|----------|-----|-----|--------|
| funct    | 7     | rs    | ;2     | rs?     | l   | fun | ct3 |     | rd       | opc | ode | R-type |
| in       | nm[11 | :0]   |        | rs?     | l   | fun | ct3 |     | rd       | opc | ode | I-type |
| imm[11   | :5]   | rs    | ;2     | rsi     | l   | fun | ct3 | im  | m[4:0]   | opc | ode | S-type |
| imm[12,1 | 10:5] | rs    | ;2     | rs1     | l   | fun | ct3 | imm | [4:1,11] | opc | ode | B-type |
|          |       | in    | nm[31  | :12]    |     |     |     |     | rd       | opc | ode | U-type |
|          | in    | nm[20 | ,10:1, | 11,19:1 | [2] |     |     |     | rd       | opc | ode | J-type |

|       |                    | ,,,, |              | _    |      | opeode J type                                                                                                |                                         |
|-------|--------------------|------|--------------|------|------|--------------------------------------------------------------------------------------------------------------|-----------------------------------------|
|       | instruction        | fmt  | opcode       | fun3 | fun7 | semantics                                                                                                    | encoding                                |
| lui   | rd,imm20           | U    | <b>0x</b> 37 |      |      | rd = imm20 << 12                                                                                             | iiii iiii iiii iiii dddd d011 0111      |
| auipc | rd,imm20           | U    | <b>0</b> x17 |      |      | rd = pc + (imm20 << 12)                                                                                      | iiii iiii iiii iiii dddd d001 0111      |
| addi  | rd,rs1,imm12       | I    | <b>0</b> x13 | 000  |      | rd = rs1 + se(imm12)                                                                                         | iiii iiii iiii ssss s000 dddd d001 0011 |
| slti  | rd,rs1,imm12       | I    | <b>0</b> x13 | 010  |      | <pre>rd = rs1 <signed 0<="" 1="" :="" ?="" pre="" se(imm12)=""></signed></pre>                               | iiii iiii iiii ssss s010 dddd d001 0011 |
| sltiu | rd,rs1,imm12       | I    | <b>0</b> x13 | 011  |      | <pre>rd = rs1 <unsign 0<="" 1="" :="" ?="" pre="" se(imm12)=""></unsign></pre>                               | iiii iiii iiii ssss s011 dddd d001 0011 |
| xori  | rd,rs1,imm12       | I    | <b>0</b> x13 | 100  |      | rd = rs1 ^ se(imm12)                                                                                         | iiii iiii iiii ssss s100 dddd d001 0011 |
| ori   | rd,rs1,imm12       | I    | <b>0</b> x13 | 110  |      | rd = rs1   se(imm12)                                                                                         | iiii iiii iiii ssss s110 dddd d001 0011 |
| andi  | rd,rs1,imm12       | I    | <b>0</b> x13 | 111  |      | rd = rs1 & se(imm12)                                                                                         | iiii iiii iiii ssss s111 dddd d001 0011 |
| slli  | rd,rs1,imm12       | I    | <b>0</b> x13 | 001  | 0x0  | rd = rs1 << imm12[4:0]                                                                                       | 0000 000i iiii ssss s001 dddd d001 0011 |
| srli  | rd,rs1,imm12       | I    | <b>0</b> x13 | 101  | 0x0  | rd = rs1 >> imm12[4:0]                                                                                       | 0000 000i iiii ssss s101 dddd d001 0011 |
| srai  | rd,rs1,imm12       | I    | <b>0</b> x13 | 101  | 0x20 | rd = rs1 >>> imm12[4:0]                                                                                      | 0100 000i iiii ssss s101 dddd d001 0011 |
| add   | rd,rs1, <b>rs2</b> | R    | 0x33         | 000  | 0x0  | rd = rs1 + rs2                                                                                               | 0000 000t tttt ssss s000 dddd d011 0011 |
| sub   | rd,rs1, <b>rs2</b> | R    | 0x33         | 000  | 0x20 | rd = rs1 - rs2                                                                                               | 0100 000t tttt ssss s000 dddd d011 0011 |
| sll   | rd,rs1, <b>rs2</b> | R    | 0x33         | 001  | 0x0  | rd = rs1 << rs2[4:0]                                                                                         | 0000 000t tttt ssss s001 dddd d011 0011 |
| slt   | rd,rs1, <b>rs2</b> | R    | <b>0</b> x33 | 010  | 0x0  | rd = rs1 <signed 0<="" 1="" :="" ?="" rs2="" td=""><td>0000 000t tttt ssss s010 dddd d011 0011</td></signed> | 0000 000t tttt ssss s010 dddd d011 0011 |
| sltu  | rd,rs1, <b>rs2</b> | R    | <b>0</b> x33 | 011  | 0x0  | rd = rs1 <unsign 0<="" 1="" :="" ?="" rs2="" td=""><td>0000 000t tttt ssss s011 dddd d011 0011</td></unsign> | 0000 000t tttt ssss s011 dddd d011 0011 |
| xor   | rd,rs1, <b>rs2</b> | R    | <b>0</b> x33 | 100  | 0x0  | rd = rs1 ^ rs2                                                                                               | 0000 000t tttt ssss s100 dddd d011 0011 |
| srl   | rd,rs1, <b>rs2</b> | R    | <b>0</b> x33 | 101  | 0x0  | rd = rs1 >> rs2[4:0]                                                                                         | 0000 000t tttt ssss s101 dddd d011 0011 |
| sra   | rd,rs1, <b>rs2</b> | R    | <b>0</b> x33 | 101  | 0x20 | rd = rs1 >>> rs2[4:0]                                                                                        | 0100 000t tttt ssss s101 dddd d011 0011 |
| or    | rd,rs1, <b>rs2</b> | R    | <b>0</b> x33 | 110  | 0x0  | rd = rs1   rs2                                                                                               | 0000 000t tttt ssss s110 dddd d011 0011 |
| and   | rd,rs1, <b>rs2</b> | R    | <b>0</b> x33 | 111  | 0x0  | rd = rs1 & rs2                                                                                               | 0000 000t tttt ssss s111 dddd d011 0011 |
| 1b    | rd,imm12(rs1)      | I    | <b>0</b> x03 | 000  |      | rd = se(mem[rs1+se(imm12)][7:0])                                                                             | iiii iiii iiii ssss s000 dddd d000 0011 |
| 1h    | rd,imm12(rs1)      | I    | <b>0</b> x03 | 001  |      | rd = se(mem[rs1+se(imm12)][15:0])                                                                            | iiii iiii iiii ssss s001 dddd d000 0011 |
| lw    | rd,imm12(rs1)      | I    | <b>0</b> x03 | 010  |      | rd = mem[rs1+se(imm12)][31:0]                                                                                | iiii iiii iiii ssss s010 dddd d000 0011 |
| 1bu   | rd,imm12(rs1)      | I    | <b>0</b> x03 | 100  |      | rd = ze(mem[rs1+se(imm12)][7:0])                                                                             | iiii iiii iiii ssss s100 dddd d000 0011 |
| 1hu   | rd,imm12(rs1)      | I    | <b>0</b> x03 | 101  |      | rd = ze(mem[rs1+se(imm12)][15:0])                                                                            | iiii iiii iiii ssss s101 dddd d000 0011 |
| sb    | rs2,imm12(rs1)     | S    | <b>0</b> x23 | 000  |      | mem[rs1+se(imm12)][7:0] = rs2[7:0]                                                                           | iiii iiit tttt ssss s000 iiii i010 0011 |
| sh    | rs2,imm12(rs1)     | S    | <b>0x</b> 23 | 001  |      | mem[rs1+se(imm12)][15:0] = rs2[15:0]                                                                         | iiii iiit tttt ssss s001 iiii i010 0011 |
| SW    | rs2,imm12(rs1)     | S    | <b>0</b> x23 | 010  |      | mem[rs1+se(imm12)][31:0] = rs2                                                                               | iiii iiit tttt ssss s010 iiii i010 0011 |
| jal   | rd,targ20          | J    | <b>0x</b> 6f |      |      | rd = pc+4; pc += se(targ20<<1)                                                                               | iiii iiii iiii iiii dddd d110 1111      |
| jalr  | rd,imm12(rs1)      | I    | <b>0x</b> 67 | 000  |      | rd = pc+4; pc = (rs1+se(imm12)) & ~0x1                                                                       | iiii iiii iiii ssss s000 dddd d110 0111 |

| beq    | rs1,rs2,targ12   | В | <b>0</b> x63 | 000 |      | if $(rs1 == rs2)$ pc += se(targ12<<1)                                                                                                                                          | iiii | iiit | tttt | SSSS | s000 | iiii | i110 | 0011 |
|--------|------------------|---|--------------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|------|------|------|------|
| bne    | rs1,rs2,targ12   | В |              | 001 |      | if (rs1 != rs2) pc += se(targ12<<1)                                                                                                                                            |      |      |      |      |      |      |      |      |
| blt    | rs1,rs2,targ12   | В | <b>0</b> x63 | 100 |      | if (rs1 <signed +="se(targ12&lt;&lt;1)&lt;/td" pc="" rs2)=""><td>_</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></signed>                                | _    |      |      |      |      |      |      |      |
| bge    | rs1, rs2, targ12 | В | <b>0x</b> 63 | 101 |      | if (rs1 ≥signed rs2) pc += se(targ12<<1)                                                                                                                                       | iiii | iiit | tttt | SSSS | s101 | iiii | i110 | 0011 |
| bltu   | rs1,rs2,targ12   | В | <b>0x</b> 63 | 110 |      | if (rs1 <unsign +="se(targ12&lt;&lt;1)&lt;/td" pc="" rs2)=""><td>iiii</td><td>iiit</td><td>tttt</td><td>SSSS</td><td>s110</td><td>iiii</td><td>i110</td><td>0011</td></unsign> | iiii | iiit | tttt | SSSS | s110 | iiii | i110 | 0011 |
| bgeu   | rs1, rs2, targ12 | В | <b>0x</b> 63 | 111 |      | if (rs1 ≥unsign rs2) pc += se(targ12<<1)                                                                                                                                       | iiii | iiit | tttt | SSSS | s111 | iiii | i110 | 0011 |
| mul    | rd,rs1,rs2       | R | <b>0</b> x33 | 000 | 0x01 | rd = (rs1 * rs2)[31:0]                                                                                                                                                         | 0000 | 001t | tttt | SSSS | s000 | dddd | d011 | 0011 |
| mulh   | rd,rs1,rs2       | R | <b>0</b> x33 | 001 | 0x01 | rd = (signed(rs1) * signed(rs2))[63:32]                                                                                                                                        | 0000 | 001t | tttt | SSSS | s001 | dddd | d011 | 0011 |
| mulhsu | rd,rs1,rs2       | R | <b>0</b> x33 | 010 | 0x01 | rd = (signed(rs1) * unsign(rs2))[63:32]                                                                                                                                        | 0000 | 001t | tttt | SSSS | s010 | dddd | d011 | 0011 |
| mulhu  | rd,rs1,rs2       | R | <b>0</b> x33 | 011 | 0x01 | rd = (unsign(rs1) * unsign(rs2))[63:32]                                                                                                                                        | 0000 | 001t | tttt | SSSS | s011 | dddd | d011 | 0011 |
| div    | rd,rs1,rs2       | R | <b>0</b> x33 | 100 | 0x01 | rd = rs1 /signed rs2                                                                                                                                                           | 0000 | 001t | tttt | SSSS | s100 | dddd | d011 | 0011 |
| divu   | rd,rs1,rs2       | R | <b>0</b> x33 | 101 | 0x01 | rd = rs1 /unsign rs2                                                                                                                                                           | 0000 | 001t | tttt | SSSS | s101 | dddd | d011 | 0011 |
| rem    | rd,rs1,rs2       | R | <b>0</b> x33 | 110 | 0x01 | rd = rs1 %signed rs2                                                                                                                                                           | 0000 | 001t | tttt | SSSS | s110 | dddd | d011 | 0011 |
| remu   | rd,rs1,rs2       | R | <b>0</b> x33 | 111 | 0x01 | rd = rs1 %unsign rs2                                                                                                                                                           | 0000 | 001t | tttt | SSSS | s111 | dddd | d011 | 0011 |

# lui, auipc, jal, jalr, b immediates

Assembler: lui x1, 0xf\_ffff 20-bit number, unsigned

Real value: 0xffff\_f000 Top 20 bits

Encoded value: 0xffff\_f000

Type: U type

| inst[31] | inst[30:20] | inst[19:12] | — 0 — |        | U-immediate |
|----------|-------------|-------------|-------|--------|-------------|
|          |             |             |       |        |             |
|          | imn         | n[31:12]    | rd    | opcode | U-type      |

| Instruction                             | Encoded Value | Assembler Value |
|-----------------------------------------|---------------|-----------------|
| 000000000000000000000000000000000000000 | 0             | 0               |
| 000000000000000000000000000000000000000 | 1             | 1               |
| 111111111111111111                      | 1 048 575     | 1 408 575       |
| 100000000000000000000000000000000000000 | 524 288       | 524288          |

# lui, auipc, jal, jalr, b immediates

Top 20 bits

20-bit number, unsigned

Assembler: aupic x1, 0xf\_ffff

Real value: 0xffff\_f000

Encoded value: 0xffff\_f000

Type: U type

| inst[31] | inst[30:20] | inst[19:12] | — 0 — |        | U-immediate |
|----------|-------------|-------------|-------|--------|-------------|
|          |             |             |       |        |             |
|          | imn         | n[31:12]    | rd    | opcode | U-type      |

| Instruction                             | Encoded Value | Assembler Value |
|-----------------------------------------|---------------|-----------------|
| 000000000000000000000000000000000000000 | 0             | 0               |
| 000000000000000000000000000000000000000 | 1             | 1               |
| 111111111111111111                      | 1 048 575     | 1 408 575       |
| 100000000000000000000000000000000000000 | 524 288       | 524288          |

#### lui, auipc, jal, jalr,b immediates

Assembler: jal x1, 0x1f\_fffe 21-bit, imm[20:1], imm[0] is 0

Real value: 0x001f\_fffe

Encoded value: 0x000f\_ffff 20-bit, imm[0] is not stored

Type: J type

Note: As bit 0 is 0, only 20 bits are encoded into the instruction

 imm[20]
 imm[10:1]
 imm[11]
 imm[19:12]
 rd
 opcode
 J-type

| Instruction                                    | Encoded Value | Assembler Value |
|------------------------------------------------|---------------|-----------------|
| <b>0_000000000_0_00000000</b> _00001_11011_11  | 0             | 0               |
| <b>0_000000001_0_00000000</b> _00001_11011_11  | 1             | 2               |
| <b>0_111111111_0_00000000</b> _00001_11011_11  | 1023          | 2046            |
| <b>0_000000000_1_00000000</b> _00001_11011_11  | 1024          | 2048            |
| <b>0_111111111_1_00000000</b> _00001_11011_11  | 2047          | 4094            |
| <b>0_111111111_1_00000001</b> _00001_11011_11  | 2048          | 4096            |
| <b>0_111111111_1_111111111</b> _00001_11011_11 | 524 287       | 1 048 574       |
| <b>1_000000000_0_00000000</b> _00001_11011_11  | -524 288      | -1 048 576      |
| <b>1_000000001_0_00000000</b> _00001_11011_11  | -523 287      | -1 048 574      |
| <b>1_111111111_0_00000000</b> _00001_11011_11  | -523 265      | -1 046 530      |
| <b>1_111111111_1_00000000</b> _00001_11011_11  | -522 241      | -1 044 482      |
| <b>1_111111111_1_00000001</b> _00001_11011_11  | -520 192      | -1 040 386      |
| <b>1_111111111_1_11111111</b> _00001_11011_11  | -1            | -2              |

### lui, auipc, jal, jalr,b immediates

Assembler: jalr x1, 0xfff(x2) 12-bit number

Real value: 0x0000\_0fff Encoded value: 0x0000\_0fff

Type: I type

Note: Bottom bit set to 0 after adding to rs1

| — inst[31] — | inst[3 | 0:25]   inst[24:21] | inst[20] | I-immediate |
|--------------|--------|---------------------|----------|-------------|
|              |        |                     |          |             |

| imm[11:0] | rs1 | funct3 | rd | opcode | ] I-type |
|-----------|-----|--------|----|--------|----------|
|-----------|-----|--------|----|--------|----------|

| Instruction                                   | Encoded Value | Assembler Value |
|-----------------------------------------------|---------------|-----------------|
| <b>00000000000</b> _00010_000_00001_11001_11  | 0             | 0               |
| <b>00000000001</b> _00010_000_00001_11001_11  | 1             | 1               |
| <b>011111111111</b> _00010_000_00001_11001_11 | 2047          | 2047            |
| <b>10000000000</b> _00010_000_00001_11001_11  | -2048         | -2048           |
| <b>11111111111</b> _00010_000_00001_11001_11  | -1            | -1              |

#### lui, auipc, jal, jalr,b immediates

Assembler: beq x1, x2,  $0x000_1$ ffe 13-bit imm[12:1], imm[0] is 0

Real value: 0x0000\_1ffe

Encoded value: 0x0000\_0fff 12-bit, imm[0] is not stored

Type: B type

Note: As bit 0 is 0, only 12 bits are encoded into the instruction

| — inst              | [31] — | inst[7 | 7]   inst[30:25] | inst[11:8]     | 0      | B-immediate |
|---------------------|--------|--------|------------------|----------------|--------|-------------|
| imm[12]   imm[10:5] | rs2    | rs1    | funct3   imm[    | 4:1]   imm[11] | opcode | B-type      |

| Instruction                                                        | Encoded Value | Assembler Value |
|--------------------------------------------------------------------|---------------|-----------------|
| <b>0_000000</b> _00010_00001_000_ <b>0000</b> _ <b>0</b> _11000_11 | 0             | 0               |
| <b>0_000000</b> _00010_00001_000_ <b>0001_0</b> _11000_11          | 1             | 2               |
| <b>0_000000</b> _00010_00001_000_ <b>1111_0</b> _11000_11          | 15            | 30              |
| <b>0_000001</b> _00010_00001_000_ <b>0000_0</b> _11000_11          | 16            | 32              |
| <b>0_111111_</b> 00010_00001_000_ <b>1111_0</b> _11000_11          | 1023          | 2046            |
| <b>0_000000</b> _00010_00001_000_ <b>0000_1</b> _11000_11          | 1024          | 2048            |
| <b>0_000000</b> _00010_00001_000_ <b>0001_1</b> _11000_11          | 1025          | 2050            |
| <b>0_111111_</b> 00010_00001_000_ <b>1111_1</b> _11000_11          | 2047          | 4094            |
| <b>1_111111_</b> 00010_00001_000_ <b>1111_1</b> _11000_11          | -1            | -2              |
| <b>1_000000</b> _00010_00001_000_ <b>0001_1</b> _11000_11          | -1028         | -2046           |
| <b>1_000000</b> _00010_00001_000_ <b>00000_0</b> _11000_11         | -2048         | -4096           |

| Inst<br>Type | Bits | Hex max       | Total range | Unsigned<br>max | Bit Range     |                      | Instruction Range                                                                    |
|--------------|------|---------------|-------------|-----------------|---------------|----------------------|--------------------------------------------------------------------------------------|
| I            | 12   | 0x00 00 0F FF | 4096        | 4095            | -2048         | 2047                 | -2048 to 2047                                                                        |
| S            | 12   | 0x00 00 0F FF | 4096        | 4095            | -2048         | 2047                 | -2048 to 2047                                                                        |
| U            | 20   | 0x00 0F FF FF | 1 048 576   | 1 048 575       | -524 288<br>0 | 524 287<br>1 048 575 | -2 147 483 648 to 2 147 483 647 in steps of 4096<br>0 to 4294967295 in steps of 4096 |
| В            | 12   | 0x00 00 0F FF | 4096        | 4095            | -2048         | 2047                 | -4096 to 4095 in steps of 2                                                          |
| J            | 20   | 0x00 0F FF FF | 1 048 576   | 1 048 575       | -524 288      | 524 287              | -1 048 576 to 1 048 575 in steps of 2                                                |
| J            | 21   | 0x00 1F FF FF | 2 097 152   | 2 097 151       | -1 048 576    | 1 048 575            |                                                                                      |

|                | Control signals |           |           |        |              |              |               |           |           |          |             |
|----------------|-----------------|-----------|-----------|--------|--------------|--------------|---------------|-----------|-----------|----------|-------------|
| instruction    | opcode          | alu_a_src | alu_b_src | rd_src | reg_write_en | data_read_en | data_write_en | data_size | alu_op    | imm_type | branch_cond |
| arithmetic reg | 011_0011        | 0         | 0         | 00     | 1            | 0            | 0             | 000       | see table | 0        | 010         |
| arithmetic imm | 001_0011        | 0         | 1         | 00     | 1            | 0            | 0             | 000       | see table | 1        | 010         |
| load           | 000_0011        | 0         | 1         | 01     | 1            | 1            | 0             | see table | 0000      | 1        | 010         |
| store          | 010_0011        | 0         | 1         | 00     | 0            | 0            | 1             | see table | 0000      | 2        | 010         |
| branch         | 110_0011        | 1         | 1         | 00     | 0            | 0            | 0             | 000       | 0000      | 3        | see table   |
| jal            | 110_1111        | 1         | 1         | 00     | 0            | 0            | 0             | 000       | 0000      | 4        | 011         |
| jalr           | 110_0111        | 0         | 1         | 10     | 1            | 0            | 0             | 000       | 0000      | 1        | 011         |
| lui            | 011_0111        | 0         | 1         | 00     | 1            | 0            | 0             | 000       | 0000      | 5        | 010         |
| auipc          | 001_0111        | 1         | 1         | 00     | 1            | 0            | 0             | 000       | 0000      | 5        | 010         |

|             | Immediate encoding |                |                |  |  |
|-------------|--------------------|----------------|----------------|--|--|
| Instruction | Opcode             | Immediate Type | Immediate Code |  |  |
| add         | 011_0011           | R              | 0              |  |  |
| addi        | 001_0011           | I              | 1              |  |  |
| lw          | 000_0011           | I              | 1              |  |  |
| SW          | 010_0011           | S              | 2              |  |  |
| beq         | 110_0011           | В              | 3              |  |  |
| jal         | 110_1111           | J              | 4              |  |  |
| jalr        | 110_0111           | I              | 1              |  |  |
| lui         | 011_0111           | U              | 5              |  |  |
| auipc       | 001_0111           | U              | 5              |  |  |

| Immediate types   |                   |  |  |  |
|-------------------|-------------------|--|--|--|
| Immediate<br>Type | Immediate<br>Code |  |  |  |
| R                 | 0                 |  |  |  |
| I                 | 1                 |  |  |  |
| S                 | 2                 |  |  |  |
| В                 | 3                 |  |  |  |
| J                 | 4                 |  |  |  |
| U                 | 5                 |  |  |  |

| alu_a_src |        |  |  |
|-----------|--------|--|--|
| Value     | Source |  |  |
| 0         | rs1    |  |  |
| 1         | рс     |  |  |

| alu_b_src |         |  |  |
|-----------|---------|--|--|
| Value     | Source  |  |  |
| 0         | rs2     |  |  |
| 1         | ext_imm |  |  |

| mem_to_reg |                 |  |  |
|------------|-----------------|--|--|
| Value      | Source          |  |  |
| 00         | alu_out         |  |  |
| 01         | data_read_value |  |  |
| 10         | pc + 4          |  |  |
| 11         |                 |  |  |

| branch_cond       |                        |  |  |
|-------------------|------------------------|--|--|
| Value Description |                        |  |  |
| 000               | a == b                 |  |  |
| 001               | a != b                 |  |  |
| 010               | no branch              |  |  |
| 011               | always branch          |  |  |
| 100               | signed(a) < signed(b)  |  |  |
| 101               | signed(a) >= signed(b) |  |  |
| 110               | a < b                  |  |  |
| 111               | a >= b                 |  |  |

| data_size |                    |  |  |  |
|-----------|--------------------|--|--|--|
| Value     | Description        |  |  |  |
| 000       | byte               |  |  |  |
| 001       | half-word          |  |  |  |
| 010       | word               |  |  |  |
| 011       |                    |  |  |  |
| 100       | unsigned byte      |  |  |  |
| 101       | unsigned half-word |  |  |  |
| 110       |                    |  |  |  |
| 111       |                    |  |  |  |

| ALU Op   |        |           |           |                                   |        |  |  |
|----------|--------|-----------|-----------|-----------------------------------|--------|--|--|
| opcode   | funct3 | funct7[5] | Operation | Function                          | ALU Op |  |  |
| 0?1_0011 | 000    | 0         | add       | alu_out = a + b                   | 0000   |  |  |
| 0?1_0011 | 000    | 1         | sub       | alu_out = a - b                   | 1000   |  |  |
| 0?1_0011 | 001    | 0         | sll       | alu_out = a << b[4:0]             | 0001   |  |  |
| 0?1_0011 | 010    | 0         | slt       | alu_out = a < signed(b) ? 1 : 0   | 0010   |  |  |
| 0?1_0011 | 011    | 0         | sltu      | alu_out = a < unsigned(b) ? 1 : 0 | 0011   |  |  |
| 0?1_0011 | 100    | 0         | xor       | alu_out = a ^ b                   | 0100   |  |  |
| 0?1_0011 | 101    | 0         | srl       | alu_out = a >> b[4:0]             | 0101   |  |  |
| 0?1_0011 | 101    | 1         | sra       | alu_out = a >>> b[4:0]            | 1101   |  |  |
| 0?1_0011 | 110    | 0         | or        | alu_out = a   b                   | 0110   |  |  |
| 0?1_0011 | 111    | 0         | and       | alu_out = a & b                   | 0111   |  |  |
|          |        |           |           | alu_out = b                       | 1001   |  |  |

| opcode   |     |       |  |  |  |  |
|----------|-----|-------|--|--|--|--|
| Value    | а   | b     |  |  |  |  |
| 001_0011 | rs1 | imm12 |  |  |  |  |
| 011_0011 | rs1 | rs2   |  |  |  |  |

|                 |                  | Byte offset          | Byte offset                | Byte offset             | Byte offset          |
|-----------------|------------------|----------------------|----------------------------|-------------------------|----------------------|
|                 | Address          | 0b11 0b10 0b01 0b00  | 0b11 0b10 0b01 0b00        | 0b11 0b10 0b01 0b00     | 0b11 0b10 0b01 0b00  |
| Store byte      | 0×1004<br>0×1000 | 7:0                  | 7:0                        | 7:0                     | 7:0                  |
| Store half-word | 0×1004<br>0×1000 | 15:8 7:0             | 15:8 7:0                   | 15:8 7:0                | 7:0                  |
| Store word      | 0×1004<br>0×1000 | 31:24 23:16 15:8 7:0 | 23:16   15:8   7:0   31:24 | 31:24 23:16<br>15:8 7:0 | 7:0 31:24 23:16 15:8 |